home
***
CD-ROM
|
disk
|
FTP
|
other
***
search
/
Aminet 24
/
Aminet 24 (1998)(GTI - Schatztruhe)[!][Apr 1998].iso
/
Aminet
/
dev
/
c
/
AmiVoGL_MDEV.lha
/
examples
/
floc.F
< prev
next >
Wrap
Text File
|
1991-06-03
|
1KB
|
92 lines
c
c a routine to demonstrate using locator.
c
program flocator
#ifdef SGI
#include "fgl.h"
#include "fdevice.h"
#else
#include "fvogl.h"
#include "fvodevice.h"
#endif
integer bt
integer *2 x, y, sx, sy
logical act, curpnt
integer *2 val, vminx, vmaxx, vminy, vmaxy
c
c Note the declaration of the function locator below
c
call winope('floc', 4)
call getvie(vminx, vmaxx, vminy, vmaxy)
xmin = vminx
xmax = vmaxx
ymin = vminy
ymax = vmaxy
call ortho2(xmin, xmax, ymin, ymax)
call color(BLACK)
call clear
call color(BLUE)
c
c draw some axes
c
y = (vmaxy - vminy) / 2
call move2s(vminx, y)
call draw2s(vmaxx, y)
x = (vmaxx - vminx) / 2
call move2s(x, vminy)
call draw2s(x, vmaxy)
call color(GREEN)
c
c enable the mouse buttons
c
call unqdev(INPUTC)
call qdevic(LEFTMO)
call qdevic(MIDDLE)
act = .false.
curpnt = .false.
c
c qread waits for a mouse event and getval tells us
c the valuator's value. In this case it's the X and Y
c positions of the mouse. Note: these come back to us in
c screen coordinates.
c
1 continue
bt = qread(val)
sx = getval(MOUSEX)
sy = getval(MOUSEY)
if (bt .eq. MIDDLE) then
call gexit
stop
else if (act) then
act = .false.
call move2s(sx, sy)
call draw2s(x, y)
else
act = .true.
x = sx
y = sy
end if
c
c swallow the up event...
c
bt = qread(val)
goto 1
end